# **Verilog Assignment 5**

### **Team Members:**

# Yash Kumar (21CS30059)

# **Sampreeth R S (21CS30038)**

In this assignment, we have calculated the value of y=x/255 for any 32-bit x, without using any multiplier or divider.

To input 32 bits of x with only 16 switches on the FPGA board, we have used reset button to first load lower 16 bits and then another reset button to load upper 16 bits and show the output on the LEDs.

Also, the output is of 24 bits so first lower 16 bits are displayed with one reset button and pressing another reset button, we get the upper 8 bits of the output.

We first carried out our simulation with the algorithm given in the class which works only with values of x which are multiples of 255. We then implemented another algorithm, which works for all values of x and gives floor of x/255 as the answer.

### Example:

(x=8796458, (in binary) 0000000100001100 011100100101010,

Y=x/255=34495, (in binary) 00000000 1000011010111111)

To carry out our algorithm, we have used carry lookahead adder (allowed by professor) and right shift modules. The algorithm is given in the picture below:

We use the following algorithm to get the value of 
$$y$$
:

 $x = x+1$ .

 $z = x>>8$ .

You that i in trange [0,3]:

 $z = (z+2c)>>8$ .





Lower 16 bits output of y obtained on the FPGA board (10000110101111):

